package com.kx.my01;

import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;

import java.util.Date;

/**
 * @Aspect：是aspectj框架中的注解。
 *      作用：表示当前类是切面类。
 *      切面类：是用来给业务方法增加功能的类，在这个类中有切面的功能代码
 */
@Aspect
public class MyAspect {
    /**
     * 定义方法，方法是实现切面功能的。
     * 方法的定义要求：
     * 1、公共方法public
     * 2、方法没有返回值
     * 3、方法名称自定义
     * 4、方法如果有参数，那么参数不是自定义的，有几个参数类型可以使用
     */
    /**
     * @Before:前置通知注解
     *  属性：value，是切入点表达式，表示切面的功能执行的位置
     */
    /*@Before(value="execution(public void com.kx.my01.SomeServiceImpl.doSome(String,Integer))")
    public void myBefore(){
        System.out.println("1====前置通知，切面功能：在目标方法前输出执行时间："+new Date());
    }*/
    /*@Before(value="execution(void com.kx.my01.SomeServiceImpl.doSome(String,Integer))")
    public void myBefore(){
        System.out.println("1====前置通知，切面功能：在目标方法前输出执行时间："+new Date());
    }*/
    /*@Before(value="execution(void *..SomeServiceImpl.doSome(String,Integer))")
    public void myBefore(){
        System.out.println("1====前置通知，切面功能：在目标方法前输出执行时间："+new Date());
    }*/
    /*@Before(value="execution(* *..SomeServiceImpl.doSome(..))")
    public void myBefore(){
        System.out.println("1====前置通知，切面功能：在目标方法前输出执行时间："+new Date());
    }*/
    /*@Before(value="execution(* do*(..))")
    public void myBefore2(){
        System.out.println("2====前置通知，切面功能：在目标方法前输出执行时间："+new Date());
    }*/

    /**
     * 指定通知方法中的参数：JoinPoint
     * JoinPoint：业务方法，要加入切面功能的业务方法
     *      作用是：可以在通知方法中获取方法执行时的信息，例如方法名称，方法的实参
     *      如果你的切面功能中需要用到方法的信息，就加入JoinPoint
     *      这个JoinPoint参数的值是由框架赋予，必须是第一个位置的参数
     */
    @Before(value="execution(void *..SomeServiceImpl.doSome(String,Integer))")
    public void myBefore(JoinPoint jp){
        //获取方法的完整定义
        System.out.println("方法的签名(定义)="+jp.getSignature());
        System.out.println("方法的名称="+jp.getSignature().getName());
        //获取方法的实参
        Object[] args= jp.getArgs();
        for (Object arg : args) {
            System.out.println("arg="+arg);
        }

        System.out.println("1====前置通知，切面功能：在目标方法前输出执行时间："+new Date());
    }
}
